<template>
  <el-container>
    <el-header id="header" class="navbar navbar-inverse navbar-fixed-top">
      <nav class="container">
        <div class="navbar-collapse">
          <a href="/">
            <div class="navbar-brand">Submit</div>
          </a>
          <el-menu
            :default-active="activeIndex2"
            class="el-menu-demo"
            mode="horizontal"
            @select="handleSelect"
            text-color="#fff"
            active-text-color="#e74c3c"
            background-color="#3d4450"
          >
            <el-submenu index="1">
              <template slot="title">任务管理</template>
              <el-menu-item index="1-1">任务列表</el-menu-item>
              <el-menu-item index="1-2">新建任务</el-menu-item>
            </el-submenu>
            <el-submenu index="2">
              <template slot="title">提交人管理</template>
              <el-menu-item index="2-1">提交人名单</el-menu-item>
              <el-menu-item index="2-2">新建提交人</el-menu-item>
            </el-submenu>
            <el-submenu index="3">
              <template slot="title">标签管理</template>
              <el-menu-item index="3-1">新建标签</el-menu-item>
            </el-submenu>
            <el-submenu index="4">
              <template slot="title">关于submit</template>
              <el-menu-item index="4-1">组员简介</el-menu-item>
            </el-submenu>
          </el-menu>
        </div>
      </nav>
    </el-header>
    <el-main id="boder">
      <div class="container">
        <div class="row">
          <el-col id="mainstay" :span="16">
            <div class="ct">
              <div class="mn" style="margin-top: 20px; background: #fff">
                <div
                  class="main-hnav"
                  style="padding: 10px; border-bottom: 1px solid #eeeeee"
                >
                  <h3 id="crtask" style="font-size: 16px">
                    我的名单
                    <em
                      style="
                        font-family: 'Lucida Sans Unicode', 'Lucida Grande',
                          sans-serif;
                        font-size: 12px;
                        color: #999999;
                        padding-left: 5px;
                      "
                      >/list</em
                    >
                  </h3>
                </div>
                <div class="imp_btn">
                  <el-upload
                    class="upload-demo"
                    action="http://localhost:8081/sub/impSubs"
                    :data="{ cid: cid }"
                    accept=".csv"
                    :headers="headers"
                    :before-upload="onBeforeUpload"
                    :show-file-list="false"
                  >
                    <el-button size="small" class="btn btn-primary"
                      ><i class="el-icon-plus"></i>批量导入</el-button
                    >
                  </el-upload>
                </div>
                <div class="tagList">
                  <el-col
                    v-for="(item, index) in tags"
                    :key="item"
                    :offset="index / index"
                    :span="2"
                  >
                    <span
                      class="tag sub_tag"
                      :class="[
                        selectTags[index] == 1 ? 'tag_active' : 'tag_unactive',
                      ]"
                    >
                      <i class="el-icon-collection-tag"></i>
                      <a href="#" @click.prevent="selectTag(index)">{{
                        item.value
                      }}</a>
                    </span>
                  </el-col>
                </div>
                <el-table
                  ref="filterTable"
                  :data="tableData"
                  style="width: 100%"
                >
                  <el-table-column
                    prop="id"
                    label="id"
                    sortable
                    min-width="30%"
                    column-key="date"
                  >
                  </el-table-column>
                  <el-table-column prop="name" label="姓名" min-width="20%">
                  </el-table-column>
                  <el-table-column prop="phone" label="电话" min-width="25%">
                  </el-table-column>
                  <el-table-column prop="wechat" label="微信号" minwidth="25%">
                  </el-table-column>
                </el-table>

                <div class="block" style="text-align:center">
                  <el-pagination
                    @current-change="getPageData"
                    :current-page="pageObject.pageNum"
                    :page-size="pageObject.pageSize"
                    layout="total, prev, pager, next, jumper"
                    :total="pageObject.total"
                  >
                  </el-pagination>
                </div>
              </div>
            </div>
          </el-col>

          <el-col id="sidebar" :span="4">
            <aside id="task-login">
              <div class="panel task-panel">
                <div class="panel-heading">
                  <i class="el-icon-sort-up"></i>
                  欢迎!
                  <i class="el-icon-sort-down"></i>
                </div>
                <div class="login-panel text-center">
                  <img
                    src="https://cache.cswsadlab.com/wp-content/uploads/2015/03/笑颜1-150x150.jpg"
                    alt="头像"
                    class="avatar avatar-60 wp-user-avatar wp-user-avatar-60 photo avatar-default"
                    width="60"
                    height="60"
                  />
                  <a class="user-name" href="https://vcb-s.com/wp-admin/"
                    >kamike</a
                  >
                  <a
                    class="btn btn-inverse-primary"
                    href="#"
                    @click.prevent="logout()"
                    title="退出登录"
                    >退出登录</a
                  >
                </div>
              </div>
            </aside>
          </el-col>
        </div>
      </div>
    </el-main>
    <el-footer id="task-footer">
      <div class="container">
        我们的目标是征服星河大海 Powered By
        <a href="/test" target="_blank">Submit</a>
      </div>
    </el-footer>
  </el-container>
</template>

<script>
import { formatDate } from "@/utils/dateformat.js";
import { subList } from "@/api/brand.js";
import { tagList } from "@/api/brand.js";
import { crTag } from "@/api/brand.js";
import { subTagList } from "@/api/brand.js";
import { getToken } from "@/utils/auth";

const pageParam = {
  list: [],
  pageNum: null,
  pageSize: null,
  total: null,
  totalPage: null,
};
export default {
  data() {
    return {
      activeIndex: "1",
      activeIndex2: "1",
      items: [],
      list: null,
      cid: null,
      tableData: [],
      dialogTableVisible: false,
      tags: [],
      tag: null,
      curTag: "",
      headers: {},
      selectTags: [],
      searchTags: [],
      currentPage: 1,
      pageObject: null,
    };
  },
  created() {
    this.headers.Authorization = getToken();
    this.cid = this.$route.query.cid;
    this.searchTags.push("所有");
    this.getTagList();
    this.pageObject = Object.assign({}, pageParam);
    this.getPageData(1);
    for(var i = 0; i < this.tags.length; i++){
      this.selectTags[i] = 0;
    }
  },
  methods: {
    getTagList(){
      tagList(this.cid).then((response) => {
        let data = response.data;
        for(var i = 0; i < data.length; i++) {
          let item = {};
          item.text = data[i];
          item.value = data[i];
          this.tags.push(item);
        };
      });
    },
    getPageData(val) {
      console.log(`当前页: ${val}`);
      this.tableData.splice(0, this.tableData.length);
      var params = new URLSearchParams();
      params.append("cid", this.cid);
      params.append("tags", this.searchTags);
      params.append("currentPage", val);
      params.append("pageSize", "");
      subList(params).then((response) => {
        let data = response.data;
        this.pageObject.list = data.list;
        this.pageObject.pageNum = data.pageNum;
        this.pageObject.pageSize = data.pageSize;
        this.pageObject.total = data.total;
        this.pageObject.totalPage = data.totalPage;
        for (var i = 0; i < this.pageObject.list.length; i++) {
          let item = {};
          item.id = this.pageObject.list[i].id;
          item.name = this.pageObject.list[i].name;
          item.phone = this.pageObject.list[i].phone;
          item.wechat = this.pageObject.list[i].wechat;
          this.tableData.push(item);
        }
      });
    },
    
    logout() {
      this.$store.dispatch("LogOut").then((response) => {});
      this.$router.push({
        path: "/login",
      });
    },
    onBeforeUpload(file) {
      const isCsv = file.type === "application/vnd.ms-excel";
      const isLt10M = file.size / 1024 / 1024 < 10;

      if (!isCsv) {
        this.$message.error("上传文件只能是csv文档");
      }
      if (!isLt10M) {
        this.$message.error("上传文件大小不能超过10MB");
      }
      return isCsv && isLt10M;
    },
    handleSelect(key, keyPath) {
      console.log(key, keyPath);
      if (keyPath[1] === "1-2") {
        this.$router.push({
          path: "/crtask",
          query: { cid: this.cid },
        });
      } else if (keyPath[1] === "1-1") {
        this.$router.push({
          path: "/coltask",
          query: { cid: this.cid },
        });
      } else if (keyPath[1] === "2-1") {
        this.$router.push({
          path: "/colsub",
          query: { cid: this.cid },
        });
      } else if (keyPath[1] === "2-2") {
        this.$router.push({
          path: "/crsub",
          query: { cid: this.cid },
        });
      } else if (keyPath[1] === "3-1") {
        this.$router.push({
          path: "/crtag",
          query: { cid: this.cid },
        });
      }
    },
    selectTag(index) {
      this.selectTags[index] = this.selectTags[index] == 1 ? 0 : 1;
      console.log(this.selectTags[index]);
      //console.log(this.selectTags[index]);
      let i = this.searchTags.indexOf(this.tags[index].value);
      if(i != -1) this.searchTags.splice(i, 1);
      if(this.selectTags[index] == 1)  this.searchTags.push(this.tags[index].value);
      console.log(this.searchTags);
      this.getPageData(this.currentPage);
    },
    visibleTable() {
      this.dialogTableVisible = true;
    },
    createTag() {
      crTag(this.cid, this.tag).then((response) => {
        var data = response.data;
        this.$message(data);
        this.tags.push(this.tag);
      });
    },
    createSub() {
      this.$router.push({
        path: "/crsub",
        query: { cid: this.cid },
      });
    },
  },
};
</script>

<style scoped>
.imp_btn {
  padding: 20px;
  text-align: right;
}

.tag_active {
  background-color: #409eff;
}

.tag_unactive {
  background-color: #3d4450;
}

.sub_tag a {
  color: #ecf0f1;
}
#task-footer {
  display: block;
  text-align: center;
  color: #ecf0f1;
  padding: 50px;
  background-color: #3d4450;
}
#task-footer a {
  color: #ecf0f1;
}

#task-footer {
  display: block;
  text-align: center;
  color: #ecf0f1;
  padding: 50px;
  background-color: #3d4450;
}
#task-footer a {
  color: #ecf0f1;
}

#sidebar aside > div {
  border-radius: 4px;
  box-shadow: 1px -1px 6px rgba(155, 89, 182, 0.5);
  -webkit-box-shadow: 1px -1px 6px rgba(155, 89, 182, 0.5);
  background-color: white;
}

.panel {
  margin-bottom: 20px;
  border: 1px solid transparent;
}

.panel-heading {
  border-bottom: none;
  font-size: 14px;
  line-height: 14px;
  font-weight: normal;
}
.panel-heading {
  padding: 10px 15px;
  border-bottom: 1px solid transparent;
  border-top-right-radius: 3px;
  border-top-left-radius: 3px;
}
.login-panel {
  height: 100px;
  padding: 20px 0px;
}
.text-center {
  text-align: center;
}
.login-panel img {
  margin-right: 20px;
  border-radius: 50%;
  border: 2px solid white;
  background-color: white;
  -webkit-transition: all 0.3s ease;
  -moz-transition: all 0.3s ease;
  -o-transition: all 0.3s ease;
  transition: all 0.3s ease;
}
img {
  max-width: 100%;
  border-radius: 4px;
  vertical-align: middle;
  height: auto;
}
.login-panel .user-name {
  margin-right: 20px;
}
.btn-inverse-primary {
  color: white !important;
  background-color: #3d4450;
  border-color: #3d4450;
  -webkit-transition: all 0.3s ease;
  -moz-transition: all 0.3s ease;
  -o-transition: all 0.3s ease;
  transition: all 0.3s ease;
}
.task-panel a {
  color: #666666;
}
.btn {
  display: inline-block;
  padding: 6px 12px;
  margin-bottom: 0;
  font-size: 12px;
  font-weight: normal;
  line-height: 1.428571429;
  text-align: center;
  white-space: nowrap;
  vertical-align: middle;
  cursor: pointer;
  border: 1px solid transparent;
  border-radius: 4px;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  -o-user-select: none;
  user-select: none;
}
.btn-danger {
  color: #ffffff;
  background-color: #e74c3c;
  border-color: #e74c3c;
  transition: all 0.25s ease-in-out;
  -webkit-transition: all 0.25s ease-in-out;
  -moz-transition: all 0.25s ease-in-out;
  -o-transition: all 0.25s ease-in-out;
}
.el-header {
  background-color: #3d4450;
  border-color: #080808;
  top: 0;
  z-index: 1030;
}
#header {
  display: fixed;
  padding: 0;
  min-height: 50px;
}

.container {
  max-width: 1600px;
  margin-right: auto;
  margin-left: auto;
}

.el-menu {
  background-color: #3d4450;
  font-size: 14px;
  display: block;
}

.el-menu::after,
.el-menu::before {
  display: none;
}

.navbar-brand {
  margin-left: -15px;
  width: 200px;
  height: 50px;
  display: block;
  float: left;
  font-size: 40px;
  color: white;
  text-align: center;
}

.navbar-collapse {
  margin-left: -15px;
  margin-right: -15px;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.1);
}

#boder {
  padding: 30px 0;
}

.container {
  padding-left: 30px;
  padding-right: 20px;
}

.row {
  margin-right: -15px;
  margin-left: -15px;
}

#mainstay {
  width: 77.7777777777777%;
  float: left;
  padding-right: 15px;
  padding-left: 15px;
}

#sidebar {
  width: 22.2222222222222%;
}
body {
  word-wrap: break-word;
}
body {
  font-family: "Microsoft Yahei", Helvetica, Arial, sans-serif;
  font-size: 12px;
  line-height: 1.428571429;
  color: #3d4450;
}
a {
  text-decoration: none;
}
.ct {
  border-radius: 4px;
  box-shadow: -1px -1px 10px rgba(155, 89, 182, 0.5);
  -webkit-box-shadow: -1px -1px 10px rgba(155, 89, 182, 0.5);
  position: relative;
  margin-bottom: 30px;
  padding-bottom: 20px;
  min-height: 20px;
  padding: 19px;
  padding-bottom: 19px;
  margin-bottom: 30px;
  border-radius: 6px;
  background-color: #ffffff;
  -webkit-box-shadow: 0px 0px 10px #9b59b6;
  -moz-box-shadow: 0px 0px 10px #9b59b6;
  box-shadow: 0px 0px 10px #9b59b6;
}

.tag {
  margin-right: 5px;
  font-size: 90%;
  display: inline;
  padding: 0.2em 0.6em 0.3em;
  font-weight: bold;
  line-height: 1;
  color: #ffffff;
  text-align: center;
  white-space: nowrap;
  vertical-align: baseline;
  border-radius: 0.25em;
}
</style>